# Homework 4

(Due date: April 6<sup>th</sup> @ 5:30 pm)

Presentation and clarity are very important! Show your procedure!

### PROBLEM 1 (15 PTS)

Complete the following timing diagram (A and P are specified as hexadecimals) of the following Iterative unsigned multiplier. The circuit includes an FSM (in ASM form) and a datapath circuit. Register (for P): *sclr*: synchronous clear. Here, if *sclr* = *E* = 1, the register contents are initialized to 0. Parallel access shift registers (for A and B): If *E* = 1: *s*\_*l* = 1 → Load, *s*\_*l* = 0 → Shift



1

#### PROBLEM 2 (70 PTS)

.

- Design the iterative Circular CORDIC FX architecture with 16 iterations. i = 0, 1, 2, 3, ... 15.  $x_0, y_0, z_0$ : initial conditions.  $mode = '0' \rightarrow \text{Rotation Mode}$ .  $mode = '1' \rightarrow \text{Vectoring Mode}$ . (40 pts)
- Operation: When s = 1, x<sub>in</sub>, y<sub>in</sub>, z<sub>in</sub>, and mode are captured. Data will then be processed iteratively. When data is ready (*done* = '1'), output results appear in x<sub>out</sub>, y<sub>out</sub>, z<sub>out</sub>.
- Input/Intermediate/Output FX Format:
  - ✓ Input values:  $x_{in}, y_{in}, z_{in}$ : [16 14]. Output values:  $x_{out}, y_{out}, z_{out}$ : [16 14]
  - ✓ Intermediate values:  $z_i$ : [16 14].  $x_i, y_i$ : [20 18]. Here, we use 4 extra bits (add four 0's to the LSB) for extra precision.
  - ✓ We restrict the inputs  $x_0 = x_{in}$ ,  $y_0 = y_{in}$  to [−1,1). Then, CORDIC operations need up to 2 integer bits (determined via MATLAB simulation). For consistency, we use 2 integer bits for all input/intermediate/output data.
  - Angles: They are represented in the format [16 14]. Units: radians.
- Barrel shifters: Use the VHDL code mybarrelshifter.vhd with mode="ARITHMETIC" (signed data), N=20, SW=4, dir=`1'.









#### SIMULATION (Functional)

- **First testbench**: Simulate the circuit for the following cases. You can use  $A_n = 1.6468$ . Convert the real numbers to the signed FX format [16 14]. For each case, verify that  $x_{16}$ ,  $y_{16}$ ,  $z_{16}$  reach the proper values. (10 pts)
  - ✓ Rotation Mode:  $x_0 = 0, y_0 = 1/A_n, z_0 = \pi/6$ .
  - ✓ Rotation Mode:  $x_0 = 0, y_0 = 1/A_n, z_0 = -\pi/3$ .
  - ✓ Vectoring Mode:  $x_0 = y_0 = 0.8, z_0 = 0$
  - ✓ Vectoring Mode:  $x_0 = 0.5, y_0 = 1, z_0 = 0$
- **Second Testbench**: Simulate the circuit reading input values  $(x_0, y_0, z_0)$  from input text files and writing output values  $(x_{16}, y_{16}, z_{16})$  on an output text file. (20 pts). Your testbench must:
  - ✓ Read input values ( $x_0$ ,  $y_0$ ,  $z_0$ ) from two input text files:
    - □ in\_benchR.txt: Data for Rotation Mode testing. 20 data points ( $x_0$ ,  $y_0$ ,  $z_0$ ). Data format: [16 14]. Each line per data point written as hexadecimals:  $|x_0|y_0|z_0|$ . Data set:  $x_0 = 0$ ,  $y_0 = 1/A_n$ ,  $z_0 = -\pi/2$  to  $\pi/2$ .  $z_0$ : 20 equally-spaced values between  $-\pi/2$  to  $\pi/2$ . With this data set in the rotation mode, note that  $x_{16} \rightarrow -sin(z_0)$ ,  $y_{16} \rightarrow cos(z_0)$ .
    - □ in\_benchV.txt: Data for Vectoring Mode testing. 20 data points ( $x_0$ ,  $y_0$ ,  $z_0$ ). Data format: [16 14]. Each line per data point written as hexadecimals:  $|x_0|y_0|z_0|$ . Data set:  $x_0 = 0.0 \text{ to } 0.5, y_0 = 1, z_0 = 0. x_0$ : 20 equally-spaced values between 0.0 to 0.5. With this data set in the vectoring mode, note that  $x_{16} \rightarrow A_n \sqrt{x_0^2 + y_0^2}, z_{16} \rightarrow atan(y_0/x_0)$ .
  - ✓ Write output results ( $x_{16}$ ,  $y_{16}$ ,  $z_{16}$ ) on out\_bench.txt. Data format: [16 14], each line per data point written as hexadecimals:  $|x_{16}|y_{16}|z_{16}|$ . The output text file should have 40 data points (20 from the rotation mode and 20 from the vectoring mode).
  - ✓ Vivado tips:
    - Make sure that the input text files are loaded as simulation sources.
    - The output text file should appear in sim/sim\_1/behav.
    - To verify that the output results are correct, you need to represent data as fixed-point numbers. Use Radix  $\rightarrow$  Real Settings in the Vivado simulator window.
  - ✓ Submit (<u>as a .zip file</u>) the generated files: VHDL code, VHDL testbenches, and output text file to Moodle (an assignment will be created). DO NOT submit the whole Vivado Project.
  - For this Problem 2, you can work in teams of up to two (2) students. Only one Moodle submission per team, make sure to indicate who you worked with in your Homework 4 assignment.

## PROBLEM 3 (15 PTS)

Attach a printout of your Project Status Report (no more than three pages, single-spaced, 2 columns). This report should contain the current status of the project. You <u>MUST</u> use the provided template (Final Project - Report Template.docx).